技術問答
技術文章
iT 徵才
聊天室
2026 鐵人賽
登入/註冊
問答
文章
Tag
邦友
鐵人賽
搜尋
2024 iThome 鐵人賽
DAY
16
0
佛心分享-IT 人自學之術
【現在學React還來得及嗎?】30天Takeaway分享
系列 第
16
篇
【Day16】Effect1
16th鐵人賽
react
haruowang
2024-08-20 15:09:20
450 瀏覽
分享至
Takeaway
讓組件和React之外的系統同步
一般來說,副作用得在事件處理函數裡發生。但要是沒有特定的觸發事件,就可以使用Effect包裹副作用
不要太常使用Effect
編寫Effect的三步驟:宣告 → 指定 → (清理)
Effect預設會在每次渲染後執行,所以要指定依賴
React使用Object.is來確認依賴項是否發生變化
如果依賴項不會改變,可以不用特別清理
依賴陣列如果設定空陣列,代表組件掛載後才會執行useEffect
ref和set函數都是穩定的,所以不用放進依賴陣列
但如果無法確認傳來的是不是同個ref等等,就要放了
開發環境下,會連接兩次,斷開一次。React會多測試,不要用ref阻止
利用useEffect處理非同步請求fetch時,可能會因為請求切換太快,而遇到競態條件(Race Condition)。不引入其他套件的應對方式有AbortController
關於切換太快的效能優化方式還有節流(Throttle)函式
如果想要緩存資料而不是刪掉再請求:可使用React Query、useSWR和 React Router v6.4+等第三方解決方案
Intersection Observer:常用來觀察元素在視窗裡的可視程度
如果要使用的資料只需要載入一次,如確認登入狀態或使用本地資料,可以寫在useEffect之外
業務邏輯(如按鈕購買)不該放在useEffect裡,而該寫到事件處理函數
留言
追蹤
檢舉
上一篇
【Day15】ref
下一篇
【Day17】Effect2
系列文
【現在學React還來得及嗎?】30天Takeaway分享
共
30
篇
目錄
RSS系列文
訂閱系列文
4
人訂閱
26
【Day26】R3F 2
27
【Day27】R3F 3
28
【Day28】React Leaflet 1
29
【Day29】React Leaflet 2
30
【Day30】React Leaflet 3
完整目錄
熱門推薦
{{ item.subject }}
{{ item.channelVendor }}
|
{{ item.webinarstarted }}
|
{{ formatDate(item.duration) }}
直播中
立即報名
尚未有邦友留言
立即登入留言
iThome鐵人賽
參賽組數
902
組
團體組數
37
組
累計文章數
19831
篇
完賽人數
528
人
看影片追技術
看更多
{{ item.subject }}
{{ item.channelVendor }}
|
{{ formatDate(item.duration) }}
直播中
熱門tag
15th鐵人賽
16th鐵人賽
13th鐵人賽
14th鐵人賽
17th鐵人賽
12th鐵人賽
11th鐵人賽
鐵人賽
2019鐵人賽
javascript
2018鐵人賽
python
2017鐵人賽
windows
php
c#
linux
windows server
css
react
熱門問題
誰能證明AI是一場公司的大災難
鼎新ERP /SMART 專案成本分析..
Connect-AzureAD 的 powershell 指令
Debian 13 安裝 bind9 後找不到範例檔
MATABASE 多期比較問題請教
延續誰能證明ai是場災難
當盡力效勞堅持崗位下的自己和我們,會不會有時覺得只剩過勞
熱門回答
誰能證明AI是一場公司的大災難
鼎新ERP /SMART 專案成本分析..
Connect-AzureAD 的 powershell 指令
Debian 13 安裝 bind9 後找不到範例檔
當盡力效勞堅持崗位下的自己和我們,會不會有時覺得只剩過勞
熱門文章
終結輪詢噩夢:量化交易系統如何優雅地接收跨境股市即時串流?
好想跟 Discord 聊天就把專案寫好 : Claude Code Channels
AI網管課 - 怎麼建置10人網路 (概念篇)
筆記:.NET 併發處理 Async/Await 筆記
如何設計自己的遊戲開發同事
IT邦幫忙
×
標記使用者
輸入對方的帳號或暱稱
Loading
找不到結果。
標記
{{ result.label }}
{{ result.account }}